<template>
  <div class="Modal">
    <Row>
      <Col span="24">
        <Tabs v-model="uploadName.file_type" @on-click="onhangeTab">
          <TabPane
            v-for="(item, index) in headTab"
            :key="index"
            :label="item.title"
            :name="item.name"
          ></TabPane>
        </Tabs>
      </Col>
    </Row>
    <Row>
      <Col span="6">
        <div class="input">
          <Input
            search
            placeholder="请输入分类名称"
            v-model="uploadName.name"
            style="width: 90%"
            @on-search="changePage"
          />
        </div>
      </Col>
      <Col span="18">
        <Button
          :disabled="checkPicList.length === 0"
          @click="checkPics"
          class="mr10"
          v-if="isShow !== 0"
          style="width: 100px"
          >{{
            uploadName.file_type == 1 ? '使用选中图片' : '使用选中视频'
          }}</Button
        >
        <!-- <Upload
          :show-upload-list="false"
          :action="fileUrl"
          class="mr10"
          :before-upload="beforeUpload"
          :data="uploadData"
          :headers="header"
          :multiple="true"
          :on-success="handleSuccess"
          style="margin-top: 1px; display: inline-block"
          v-if="uploadName.file_type==1"
        >
          <Button>上传图片</Button>
        </Upload> -->
        <Button
          v-if="uploadName.file_type == 1"
          class="mr10"
          @click="openUpload"
          >上传图片</Button
        >
        <Button class="mr10" v-else @click="uploadVideo">上传视频</Button>
        <!--<Button type="success" @click.stop="add" class="mr10">添加分类</Button>-->
        <Button
          class="mr10"
          :disabled="checkPicList.length === 0"
          @click.stop="editPicList('图片')"
          >{{ uploadName.file_type == 1 ? '删除图片' : '删除视频' }}</Button
        >
        <i-select
          :value="pids"
          :placeholder="uploadName.file_type == 1 ? '图片移动至' : '视频移动至'"
          style="width: 250px"
          class="treeSel"
        >
          <i-option
            v-for="(item, index) of list"
            :value="item.value"
            :key="index"
            style="display: none"
          >
            {{ item.title }}
          </i-option>
          <Tree
            :data="treeData2"
            :render="renderContentSel"
            ref="reference"
            :load-data="loadData"
            class="selectTree"
          ></Tree>
        </i-select>
      </Col>
    </Row>
    <Row class="colLeft">
      <Col span="6" class="colLeft left">
        <div class="Nav">
          <div class="trees-coadd">
            <div class="scollhide">
              <div class="trees">
                <Tree
                  :data="treeData"
                  :render="renderContent"
                  :load-data="loadData"
                  class="treeBox"
                  ref="tree"
                >
                </Tree>

                <div
                  class="searchNo"
                  v-if="searchClass && treeData.length <= 1"
                >
                  此分类暂无数据
                </div>
              </div>
            </div>
          </div>
        </div>
      </Col>
      <Col span="18" class="colLeft right">
        <div class="conter">
          <div class="pictrueList acea-row">
            <Row :gutter="24" class="conter">
              <div v-show="isShowPic" class="imagesNo">
                <Icon type="ios-images" size="60" color="#dbdbdb" />
                <span class="imagesNo_sp">{{
                  uploadName.file_type == 1 ? '图片库为空' : '视频库为空'
                }}</span>
              </div>
              <div class="acea-row">
                <div
                  class="pictrueList_pic"
                  v-for="(item, index) in pictrueList"
                  :key="index"
                  @mouseenter="enterLeave(item)"
                  @mouseleave="enterLeave(item)"
                >
                  <p class="number" v-if="item.num > 0">
                    <Badge :count="item.num" type="error" :offset="[11, 12]">
                      <a href="#" class="demo-badge"></a>
                    </Badge>
                  </p>
                  <div class="picimage">

                    <img
                      v-if="item.file_type == 1"
                      :class="item.isSelect ? 'on' : ''"
                      v-lazy="item.poster || item.satt_dir"
                      @click.stop="changImage(item, index, pictrueList)"
                    />
                    <img
                      v-if="item.file_type == 2"
                      :class="item.isSelect ? 'on' : ''"
                      v-lazy="`${item.satt_dir}?ci-process=snapshot&time=1`"
                      style="object-fit: cover;"
                      @click.stop="changImage(item, index, pictrueList)"
                    />
                  </div>
                  <div class="picName">
                    <p v-if="!item.isEdit">
                      {{ item.editName }}
                    </p>
                    <Input
                      size="small"
                      type="text"
                      v-model="item.real_name"
                      v-else
                      @on-blur="bindTxt(item)"
                    />
                    <div class="picMenu">
                      <ButtonGroup>
                        <Button
                          size="small"
                          @click="item.isEdit = !item.isEdit"
                        >
                          <Icon type="ios-create" />
                        </Button>
                        <Button
                          size="small"
                          class="preview"
                          @click="openView(item)"
                        >
                          <Icon type="ios-eye" />
                        </Button>
                        <Button size="small" @click="editPicList(item.att_id)">
                          <Icon type="ios-trash" />
                        </Button>
                      </ButtonGroup>
                    </div>
                  </div>
                </div>
              </div>
            </Row>
          </div>
          <div class="nameStyle" v-show="openImgShow">
            <img v-if="uploadName.file_type == 1" :src="viewImg" />
            <div v-else-if="uploadName.file_type == 2" id="player"></div>
          </div>
          <div class="footer acea-row row-right">
            <Page
              :total="total"
              show-elevator
              show-total
              @on-change="pageChange"
              :current="fileData.page"
              :page-size="fileData.limit"
            />
          </div>
        </div>
      </Col>
    </Row>
    <Modal
      v-model="modalVideo"
      width="1024px"
      scrollable
      footer-hide
      closable
      title="上传视频"
      :mask-closable="false"
      :z-index="9"
    >
      <uploadVideo @getVideo="getvideo" :pid="fileData.pid"></uploadVideo>
    </Modal>
  </div>
</template>

<script>
import {
  getCategoryListApi,
  createApi,
  fileListApi,
  categoryEditApi,
  moveApi,
  fileUpdateApi,
} from '@/api/uploadPictures';
import Setting from '@/setting';
// import { getCookies } from "@/libs/util";
import util from '@/libs/util';
import uploadVideo from '@/components/uploadVideos';
export default {
  name: 'uploadPictures',
  components: {
    uploadVideo,
  },
  props: {
    isChoice: {
      type: String,
      default: '',
    },
    gridBtn: {
      type: Object,
      default: null,
    },
    gridPic: {
      type: Object,
      default: null,
    },
    isShow: {
      type: Number,
      default: 1,
    },
  },
  data() {
    return {
      searchClass: false,
      spinShow: false,
      fileUrl: Setting.apiBaseURL + '/file/upload',
      modalPic: false,
      treeData: [],
      treeData2: [],
      pictrueList: [],
      uploadData: {}, // 上传参数
      checkPicList: [],
      uploadName: {
        name: '',
        file_type: '1',
      },
      FromData: null,
      treeId: 0,
      isJudge: false,
      buttonProps: {
        type: 'default',
        size: 'small',
      },
      fileData: {
        pid: 0,
        page: 1,
        limit: 18,
      },
      total: 0,
      pids: 0,
      list: [],
      modalTitleSs: '',
      isShowPic: false,
      header: {},
      ids: [], // 选中附件的id集合
      viewImg: '',
      openImgShow: false,
      headTab: [
        { title: '图片', name: '1' },
        { title: '视频', name: '2' },
      ],
      modalVideo: false,
      // uploadList:[]
    };
  },
  watch: {
    pictrueList() {
      this.checkPicList = this.ids = [];
    },
  },
  mounted() {
    this.getToken();
    this.getList();
    this.getFileList();
    document.addEventListener(
      'click',
      (event) => {
        const nameStyleElement = document.querySelector('.nameStyle');
        if (
          (!nameStyleElement || !nameStyleElement.contains(event.target)) &&
          !event.target.classList.contains('ivu-icon-ios-eye') &&
          !event.target.classList.contains('preview')
        ) {
          this.openImgShow = false;
          this.viewImg = '';
          if (this.player) {
            this.player.dispose();
            this.player = null;
          }
        }
      },
      true
    );
  },
  methods: {
    createPoster(data) {
      new Promise((resolve, reject) => {
        let video = document.createElement('video');
        video.setAttribute('src', data.att_dir);
        video.setAttribute('crossOrigin', 'anonymous');
        video.setAttribute('width', 100);
        video.setAttribute('height', 100);
        video.setAttribute('preload', 'auto');
        video.addEventListener('canplay', () => {
          let canvas = document.createElement('canvas');
          let context = canvas.getContext('2d');
          let width = video.width;
          let height = video.height;
          canvas.width = width;
          canvas.height = height;
          context.drawImage(video, 0, 0, width, height);
          resolve(canvas.toDataURL('image/jpeg'));
        });
      }).then((url) => {
        data.poster = url;
      });
    },
    createPlayer(data) {
      if (this.player) {
        this.player.dispose();
        this.player = null;
      }
      this.player = new Aliplayer({
        id: 'player',
        width: '100%',
        height: '100%',
        autoplay: true,
        source: data.att_dir,
      });
    },
    uploadVideo() {
      this.modalVideo = true;
    },
    getvideo() {
      this.modalVideo = false;
      this.fileData.page = 1;
      this.getFileList();
    },
    onhangeTab() {
      this.treeId = 0;
      this.getList();
      this.getFileList();
      this.checkPicList = [];
    },
    enterMouse(item) {
      item.realName = !item.realName;
    },
    enterLeave(item) {
      item.isShowEdit = !item.isShowEdit;
    },
    // 上传头部token
    getToken() {
      this.header['Authori-zation'] = 'Bearer ' + util.cookies.get('token');
    },
    // 树状图
    renderContent(h, { root, node, data }) {
      let operate = [];
      if (data.pid == 0) {
        operate.push(
          h(
            'div',
            {
              class: ['ivu-dropdown-item'],
              on: {
                click: () => {
                  this.append(root, node, data);
                },
              },
            },
            '添加分类'
          )
        );
      }
      if (data.id) {
        operate.push(
          h(
            'div',
            {
              class: ['ivu-dropdown-item'],
              on: {
                click: () => {
                  this.editPic(root, node, data);
                },
              },
            },
            '编辑分类'
          ),
          h(
            'div',
            {
              class: ['ivu-dropdown-item'],
              on: {
                click: () => {
                  this.remove(root, node, data, '分类');
                },
              },
            },
            '删除分类'
          )
        );
      }
      return h(
        'span',
        {
          class: ['ivu-span'],
          style: {
            display: 'inline-block',
            width: '88%',
            height: '32px',
            lineHeight: '32px',
            position: 'relative',
            color: 'rgba(0,0,0,0.6)',
            cursor: 'pointer',
          },
          on: {
            mouseenter: () => {
              this.onMouseOver(root, node, data);
            },
            mouseleave: () => {
              this.onMouseOver(root, node, data);
            },
          },
        },
        [
          h(
            'span',
            {
              on: {
                click: (e) => {
                  this.appendBtn(root, node, data, e);
                },
              },
            },
            data.title
          ),
          h(
            'div',
            {
              style: {
                display: 'inline-block',
                float: 'right',
              },
            },
            [
              h('Icon', {
                props: {
                  type: 'ios-more',
                },
                style: {
                  marginRight: '8px',
                  fontSize: '20px',
                  display: data.flag ? 'inline' : 'none',
                },
                on: {
                  click: () => {
                    this.onClick(root, node, data);
                  },
                },
              }),
              h(
                'div',
                {
                  class: ['right-menu ivu-poptip-inner'],
                  style: {
                    width: '80px',
                    position: 'absolute',
                    zIndex: '9',
                    top: '32px',
                    right: '12px',
                    display: data.flag2 ? 'block' : 'none',
                  },
                },
                operate
              ),
            ]
          ),
        ]
      );
    },

    renderContentSel(h, { root, node, data }) {
      return h(
        'div',
        {
          style: {
            display: 'inline-block',
            width: '90%',
          },
        },
        [
          h('span', [
            h(
              'span',
              {
                style: {
                  cursor: 'pointer',
                },
                class: ['ivu-tree-title'],
                on: {
                  click: (e) => {
                    this.handleCheckChange(root, node, data, e);
                  },
                },
              },
              data.title
            ),
          ]),
        ]
      );
    },
    // 下拉树
    handleCheckChange(root, node, data, e) {
      this.list = [];
      // this.pids = 0;
      let value = data.id;
      let title = data.title;
      this.list.push({
        value,
        title,
      });
      if (this.ids.length) {
        this.pids = value;
        this.getMove();
      } else {
        this.$Message.warning('请先选择图片');
      }
      let selected = this.$refs.reference.$el.querySelectorAll(
        '.ivu-tree-title-selected'
      );
      for (let i = 0; i < selected.length; i++) {
        selected[i].className = 'ivu-tree-title';
      }
      e.path[0].className = 'ivu-tree-title'; // 当前点击的元素
    },
    // 移动分类
    getMove() {
      let data = {
        pid: this.pids,
        images: this.ids.toString(),
      };
      moveApi(data)
        .then(async (res) => {
          this.$Message.success(res.msg);
          this.getFileList();
          this.pids = 0;
          this.checkPicList = [];
          this.ids = [];
        })
        .catch((res) => {
          this.$Message.error(res.msg);
        });
    },
    // 删除图片
    editPicList(tit) {
      let ids = {
        ids: this.ids.toString(),
      };
      if (typeof tit == 'number') {
        ids = {
          ids: tit.toString(),
        };
      }
      let delfromData = {
        title: this.uploadName.file_type == 1 ? '删除选中图片' : '删除选中视频',
        url: `file/file/delete`,
        method: 'POST',
        ids: ids,
      };
      this.$modalSure(delfromData)
        .then((res) => {
          this.$Message.success(res.msg);
          this.getFileList();
          this.checkPicList = [];
        })
        .catch((res) => {
          this.$Message.error(res.msg);
        });
    },
    // 鼠标移入 移出
    onMouseOver(root, node, data) {
      event.preventDefault();
      data.flag = !data.flag;
      if (data.flag2) {
        data.flag2 = false;
      }
    },
    onClick(root, node, data) {
      data.flag2 = !data.flag2;
    },
    // 点击树
    appendBtn(root, node, data, e) {
      this.treeId = data.id ? data.id : 0;
      this.fileData.page = 1;
      this.getFileList();
      let selected = this.$refs.tree.$el.querySelectorAll(
        '.ivu-tree-title-selected'
      );
      for (let i = 0; i < selected.length; i++) {
        selected[i].className = 'ivu-tree-title';
      }
      e.path[0].className = 'ivu-tree-title'; // 当前点击的元素
    },
    // 点击添加
    append(root, node, data) {
      this.treeId = data.id;
      this.getFrom();
    },
    // 删除分类
    remove(root, node, data, tit) {
      this.tits = tit;
      let delfromData = {
        title: '删除 [ ' + data.title + ' ] ' + '分类',
        url: `file/category/${data.id}`,
        method: 'DELETE',
        ids: '',
      };
      this.$modalSure(delfromData)
        .then((res) => {
          this.$Message.success(res.msg);
          this.getList();
          this.checkPicList = [];
        })
        .catch((res) => {
          this.$Message.error(res.msg);
        });
    },
    // 确认删除树
    // submitModel () {
    //     if (this.tits === '图片') {
    //         this.getFileList();
    //         this.checkPicList = [];
    //     } else {
    //         this.getList();
    //         this.checkPicList = [];
    //     }
    // },
    // 编辑树表单
    editPic(root, node, data) {
      this.$modalForm(
        categoryEditApi(data.id, { file_type: this.uploadName.file_type })
      ).then(() => this.getList());
    },
    // 搜索分类
    changePage() {
      this.getList('search');
    },
    // 分类列表树
    getList(type) {
      let data = {
        title: this.uploadName.file_type == 1 ? '全部图片' : '全部视频',
        id: '',
        pid: 0,
        selected: true,
      };
      getCategoryListApi(this.uploadName)
        .then(async (res) => {
          this.treeData = res.data.list;
          this.treeData.unshift(data);
          if (type !== 'search') {
            this.treeData2 = [...this.treeData];
          } else {
            this.searchClass = true;
          }
          this.addFlag(this.treeData);
        })
        .catch((res) => {
          this.$Message.error(res.msg);
        });
    },
    loadData(item, callback) {
      getCategoryListApi({
        pid: item.id,
        file_type: this.uploadName.file_type,
      })
        .then(async (res) => {
          const data = res.data.list;
          callback(data);
        })
        .catch((res) => {});
    },
    addFlag(treedata) {
      treedata.map((item) => {
        this.$set(item, 'flag', false);
        this.$set(item, 'flag2', false);
        item.children && this.addFlag(item.children);
      });
    },
    // 新建分类
    add() {
      this.treeId = 0;
      this.getFrom();
    },
    // 文件列表
    getFileList() {
      this.fileData.pid = this.treeId;
      this.fileData.file_type = this.uploadName.file_type;
      fileListApi(this.fileData)
        .then(async (res) => {
          res.data.list.forEach((el) => {
            el.isSelect = false;
            el.isEdit = false;
            el.isShowEdit = false;
            el.realName = false;
            el.num = 0;
            this.editName(el);
            if (el.file_type == 2) {
              el.poster = '';
              if (el.satt_dir.includes('uploads')) {
                this.createPoster(el);
              }
            }
          });
          this.pictrueList = res.data.list;

          if (this.pictrueList.length) {
            this.isShowPic = false;
          } else {
            this.isShowPic = true;
          }
          this.total = res.data.count;
        })
        .catch((res) => {
          this.$Message.error(res.msg);
        });
    },
    pageChange(index) {
      this.fileData.page = index;
      this.getFileList();
      this.checkPicList = [];
    },
    // 新建分类表单
    getFrom() {
      this.$modalForm(
        createApi({ id: this.treeId, file_type: this.uploadName.file_type })
      ).then((res) => {
        this.getList();
      });
    },
    // 上传之前
    beforeUpload(res) {
      // if (this.uploadList.length > 4) {
      //   // this.$Message.warning("一次最多只能上传5张图片");
      //   return false;
      // }
      //控制文件上传格式
      let imgTypeArr = ['image/png', 'image/jpg', 'image/jpeg', 'image/gif'];
      let imgType = imgTypeArr.indexOf(res.type) !== -1;
      if (!imgType) {
        this.$Message.warning({
          content: '文件  ' + res.name + '  格式不正确, 请选择格式正确的图片',
          duration: 5,
        });
        return false;
      }
      // 控制文件上传大小
      let imgSize = this.$cache.local.getJSON('file_size_max');
      let Maxsize = res.size < imgSize;
      let fileMax = imgSize / 1024 / 1024;
      if (!Maxsize) {
        this.$Message.warning({
          content: '文件体积过大,图片大小不能超过' + fileMax + 'M',
          duration: 5,
        });
        return false;
      }
      // this.uploadList.push(res);
      this.uploadData = {
        pid: this.treeId,
      };
      let promise = new Promise((resolve) => {
        this.$nextTick(function () {
          resolve(true);
        });
      });
      return promise;
    },
    // 上传成功
    handleSuccess(res, file, fileList) {
      if (res.status === 200) {
        // this.uploadList = [];
        this.fileData.page = 1;
        this.$Message.success(res.msg);
        this.getFileList();
      } else {
        this.$Message.error(res.msg);
      }
    },
    // 关闭
    cancel() {
      this.$emit('changeCancel');
    },
    // 选中图片
    changImage(item, index, row) {
      let activeIndex = 0;
      // 如果是单选且选择了图片
      if (this.isChoice === '单选' && this.checkPicList.length >= 1) {
        // 如果选择的图片是列表的第一张图片
        if (this.checkPicList[0].att_id == item.att_id) {
          // 取消勾选
          item.isSelect = false;
          // 遍历图片列表使角标为0
          this.pictrueList.forEach((j) => {
            if (j.att_id == this.checkPicList[0].att_id) {
              j.num = 0;
            }
          });
          // 重置已选中数组
          this.checkPicList = [];
        } else {
          // 将选中的第一张图片角标为0
          this.checkPicList[0].num = 0;
          // 取消勾选
          this.checkPicList[0].isSelect = false;
          // 将这张图片删除
          this.checkPicList.splice(0, 1);
          // 添加下一张选中的图片
          this.checkPicList.push(item);
          // 勾选
          item.isSelect = true;
          // 显示角标为1
          item.num = 1;
        }
        return;
      }
      if (!item.isSelect) {
        item.isSelect = true;
        this.checkPicList.push(item);
      } else {
        item.isSelect = false;
        this.checkPicList.map((el, index) => {
          if (el.att_id == item.att_id) {
            activeIndex = index;
          }
        });
        this.checkPicList.splice(activeIndex, 1);
      }
      this.ids = [];
      this.checkPicList.map((item, i) => {
        this.ids.push(item.att_id);
      });
      this.pictrueList.map((el, i) => {
        if (el.isSelect) {
          this.checkPicList.filter((el2, j) => {
            if (el.att_id == el2.att_id) {
              el.num = j + 1;
            }
          });
        } else {
          el.num = 0;
        }
      });
    },
    // 点击使用选中图片
    checkPics() {
      if (this.isChoice === '单选') {
        if (this.checkPicList.length > 1)
          return this.$Message.warning('最多只能选一张图片');
        this.$emit('getPic', this.checkPicList[0]);
      } else {
        let maxLength = this.$route.query.maxLength;
        if (
          maxLength != undefined &&
          this.checkPicList.length > Number(maxLength)
        )
          return this.$Message.warning('最多只能选' + maxLength + '张图片');
        this.$emit('getPicD', this.checkPicList);
      }
    },
    editName(item) {
      let it = item.real_name.split('.');
      let it1 = it[1] == undefined ? [] : it[1];
      let len = it[0].length + it1.length;
      item.editName = item.real_name;
      // item.editName =
      //         len < 10
      //                 ? item.real_name
      //                 : item.real_name.substr(0, 2) + "..." + item.real_name.substr(-5, 5);
    },
    // 修改图片文字上传
    bindTxt(item) {
      if (item.real_name == '') {
        this.$Message.error('请填写内容');
      }
      fileUpdateApi(item.att_id, {
        real_name: item.real_name,
      })
        .then((res) => {
          this.editName(item);
          item.isEdit = false;
          this.$Message.success(res.msg);
        })
        .catch((error) => {
          this.$Message.error(error.msg);
        });
    },
    //大图预览
    openView(item) {
      if (this.viewImg == item.satt_dir) {
        this.openImgShow = false;
        this.viewImg = '';
      } else {
        this.openImgShow = true;
        if (item.file_type == 1) {
          this.viewImg = item.satt_dir;
        } else if (item.file_type == 2) {
          this.createPlayer(item);
        }
      }
    },
    openUpload() {
      this.$uploadImg({
        categories: this.treeData,
        categoryId: this.treeId,
        onClose: () => {
          this.fileData.page = 1;
          this.getFileList();
        },
      });
    },
  },
};
</script>

<style scoped lang="stylus">
.searchNo {
  margin-top: -250px;
  text-align: center;
}

.nameStyle {
  position: absolute;
  white-space: nowrap;
  z-index: 999;
  background: #eee;
  left: 150px;
  top: 100px;
  height: 300px;
  width: 300px;
  color: #555;
  border: 1px solid #ebebeb;
  padding: 0 !important;
}

.nameStyle img {
  position: absolute;
  white-space: nowrap;
  width: 99%;
  height: 99%;
  object-fit: contain;
}

.iconbianji1 {
  font-size: 13px;
}

/deep/.ivu-badge-count {
  margin-top: 18px !important;
  margin-right: 19px !important;
}

.Nav /deep/.ivu-icon-ios-arrow-forward:before {
  content: '\F341' !important;
  font-size: 20px;
}

/deep/.ivu-btn-icon-only.ivu-btn-small {
  padding: unset !important;
}

.selectTree {
}

.treeBox {
  width: 100%;
  height: 100%;
  margin-top: 10px;

  >>> ul {
    padding: 0;
  }

  >>> ul li {
    margin: 0;
  }

  >>> .ivu-tree-arrow {
    width: 17px;
    color: #626262;
  }

  >>> .ivu-span:hover {
    // background: #F5F5F5;
    color: rgba(0, 0, 0, 0.4) !important;
  }

  >>> .ivu-tree-arrow i {
    vertical-align: bottom;
  }

  // /deep/ivu-tree-title-selected:hover {
  // color: unset;
  // background-color: unset;
  // }
  >>> .ivu-tree-title {
    padding: 5px 0;
    display: unset !important;
    vertical-align: unset;
  }

  >>> .ivu-tree-title .ivu-span>span {
    padding-left: 5px;
  }

  // >>> .ivu-tree-title-selected{
  // width : 100%;
  // }
  >>> .ivu-tree-title-selected, .ivu-tree-title-selected:hover {
    color: #2D8cF0 !important;
    background-color: #f0faff !important;
  }

  // >>> .ivu-tree-title-selected span{
  // color: #2D8cF0 !important;
  // background-color: #f0faff !important;
  // }
  >>> .ivu-btn-icon-only {
    width: 20px !important;
    height: 20px !important;
  }

  >>> .ivu-tree-title:hover {
    color: #2D8cF0 !important;
    background-color: #f0faff !important;
  }
}

.trees-coadd {
  width: 100%;
  border-radius: 4px;
  overflow: hidden;
  position: relative;

  .scollhide {
    overflow-x: hidden;
    overflow-y: scroll;
    padding: 0;
    box-sizing: border-box;

    .trees {
      width: 100%;
      height: 450px;
    }
  }

  .scollhide::-webkit-scrollbar {
    width: 4px !important; /* 对垂直流动条有效 */
  }

  /* 定义滑块 内阴影+圆角 */
  ::-webkit-scrollbar-thumb {
    -webkit-box-shadow: inset 0 0 6px #999;
  }
}

.treeSel >>>.ivu-select-dropdown-list {
  padding: 0 5px !important;
  box-sizing: border-box;
  width: 200px;
}

.imagesNo {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  margin: 65px auto;

  .imagesNo_sp {
    font-size: 13px;
    color: #dbdbdb;
    line-height: 3;
  }
}

.Modal {
  width: 100%;
  height: 100%;
  background: #fff !important;
}

.Nav {
  width: 90%;
  border-right: 1px solid #eee;
}

.colLeft {
  padding-right: 0 !important;
  height: 100%;
}

.conter {
  width: 100%;
  height: 100%;
  margin-left: -4px !important;
  min-height: 405px;
  display: block;
  position: relative;
}

.conter .bnt {
  width: 100%;
  padding: 0 13px 0 12px;
  box-sizing: border-box;
}

.conter .pictrueList_pic {
  position: relative;
  width: 100px;
  height: 125px;
  cursor: pointer;
  margin: 5px 8px;
  padding: 0px;
  border-radius: 3px;
  display: inline-block;

  .picimage {
    width: 100px;
    height: 100px;
    background-color: #f0f0f0 !important;
  }

  .picimage img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  // .picimage .picMenu {
  // position: absolute
  // bottom: 30px
  // // background-color: rgba(0,0,0,0.5)
  // width:100px
  // // display:none
  // text-align: center
  // }
  .picName {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: #fff !important;
    padding: 5px;
  }

  .picName .picMenu {
    position: absolute;
    bottom: 18px;
    left: 0;
    // background-color: rgba(0,0,0,0.5)
    width: 100px;
    display: none;
    text-align: center;
  }

  .picName:hover .picMenu {
    display: block;
  }

  p {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    height: 20px;
    text-align: center;
  }

  .number {
    height: 33px;
  }

  .number {
    position: absolute;
    right: 0;
    top: 0;
  }
}

.conter .pictrueList {
  width: 100%;
  height: 100%;
  margin-top: 10px;
}

.conter .pictrueList img {
  width: 100%;
  vertical-align: middle;
}

.conter .pictrueList img.on {
  border: 2px solid #5FB878;
}

.conter .footer {
  padding: 10px 20px;
}

.demo-badge {
  width: 42px;
  height: 42px;
  background: transparent;
  border-radius: 6px;
  display: inline-block;
}

.bnt /deep/ .ivu-tree-children {
  padding: 5px 0;
}

.trees-coadd /deep/ .ivu-tree-children .ivu-tree-arrow {
  line-height: 18px;
}
</style>
